And use it to fix the palette parser.
GtkCssValue *result, *color;
char *ident;
- if (_gtk_css_parser_try (parser, "default", TRUE))
+ if (gtk_css_parser_try_ident (parser, "default"))
return gtk_css_palette_value_new_default ();
result = gtk_css_palette_value_new_empty ();
do {
- ident = _gtk_css_parser_try_ident (parser, TRUE);
+ ident = gtk_css_parser_consume_ident (parser);
if (ident == NULL)
{
- _gtk_css_parser_error (parser, "expected color name");
_gtk_css_value_unref (result);
return NULL;
}
gtk_css_palette_value_add_color (result, ident, color);
g_free (ident);
- } while (_gtk_css_parser_try (parser, ",", TRUE));
+ } while (gtk_css_parser_try_token (parser, GTK_CSS_TOKEN_COMMA));
return result;
}
return TRUE;
}
+char *
+gtk_css_parser_consume_ident (GtkCssParser *self)
+{
+ char *result;
+
+ result = _gtk_css_parser_try_ident (self, TRUE);
+ if (result == NULL)
+ _gtk_css_parser_error (self, "Expected an identifier");
+
+ return result;
+}
+
gboolean
gtk_css_parser_consume_number (GtkCssParser *self,
double *number)
gboolean _gtk_css_parser_try_hash_color (GtkCssParser *parser,
GdkRGBA *rgba);
+char * gtk_css_parser_consume_ident (GtkCssParser *self);
gboolean gtk_css_parser_consume_number (GtkCssParser *self,
double *number);
gboolean gtk_css_parser_consume_function (GtkCssParser *self,
g_return_val_if_fail (parser != NULL, NULL);
- ident = _gtk_css_parser_try_ident (parser, TRUE);
+ ident = gtk_css_parser_consume_ident (parser);
if (ident == NULL)
return NULL;
{
char *name;
- name = _gtk_css_parser_try_ident (parser, TRUE);
- if (name)
+ if (gtk_css_parser_has_token (parser, GTK_CSS_TOKEN_IDENT))
{
- GString *string = g_string_new (name);
+ GString *string = g_string_new (NULL);
+
+ name = gtk_css_parser_consume_ident (parser);
+ g_string_append (string, name);
g_free (name);
- while ((name = _gtk_css_parser_try_ident (parser, TRUE)))
+ while (gtk_css_parser_has_token (parser, GTK_CSS_TOKEN_IDENT))
{
+ name = gtk_css_parser_consume_ident (parser);
g_string_append_c (string, ' ');
g_string_append (string, name);
g_free (name);